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BACKGROUND OF THE INVENTION 
15 1 . Field of the Invention 

The present invention relates generally to transmitting information over computer 
networks, and more particularly, to a system and method for executing a remote 
procedure call (RPC) from a Web page displayed in a Web browser to a server. 

20 2. Description of the Related Art 

The Internet is a computer network that provides access to the World Wide Web 
("the Web"); a vast collection of pages comprised of text, hyperlinks, graphical elements, 
input elements (e.g. HTML text box), and program code (e.g. JavaScript). Graphical user 
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interface programs called Web browsers are employed by Internet users to receive, or 
download, the Web pages from servers and display the pages at their client devices. A 
Web browser displays Web pages by interpreting the HTML document and executing any 
program code, which results in the showing text, hyperlinks, graphical elements, and 
5 input elements on a client display screen. 

The rapid increase in the number of Internet users and the ubiquity of the Web 
browser have prompted companies to adopt Web pages for delivering, to end-users, time- 
sensitive information and mission-critical software applications. These Web-based 
applications generally require numerous transmissions of data between a server and the 

10 Web browser. Traditionally, for each transmission of data, a new page must be 

transmitted back to the user or their existing page must be refreshed. This traditional data 
transmission model, when used in the context of delivering web-based applications to 
end-users, greatly increases the number of redundant Web page refreshes. Web page 
refreshes are problematic, because they result in unnecessary server and bandwidth 

15 utilization, and force the user to wait for redundant pages to load. This negatively 

impacts the Web-based application's effectiveness and the Internet user's productivity, 
while compromising network efficiency and scalability. 

Several developments illustrate the great effort at reducing redundant page 
refreshes and for providing a rich interactive user experience for Web pages without 

20 utilizing Web browser plug-ins, such as Macromedia's Flash player or Microsoft's 
ActiveX controls. One of which was developed and promoted by Microsoft. 

Microsoft developed a Java Applet-based technology called "Remote Scripting", 
which allows information to be exchanged between a displayed Web page and the server, 
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without having to refresh the page. After several years of promotion by Microsoft, 
however, "Remote Scripting" technology has not been widely adopted by Web 
developers. There are several reasons for this: 

L Slow: In order to use "Remote Scripting," each Web page must include a Java 
5 Applet, acting as the client-side communication proxy, which must initialize Java 

Virtual Machine at the client's computer. Initialization of Java Virtual Machine 
and loading of the Java Applet is a slow process that introduces an undesirable 
delay in displaying the Web page for most personal computers. 
2. Limited Server Compatibility: "Remote Scripting" only supports Microsoft Web 
10 server software, such as Microsoft's IIS (Internet Information Server). Most high 

traffic and established commercial Websites, however, use a non-Microsoft 
platform or wish not to be limited to only using the Microsoft platform in the 
future. 

As a result of these serious limitations, most Web-based applications do not or cannot 

15 take advantage of Microsoft's "Remote Scripting" technology. 

Consequently, the most common method for achieving real-time Web page 
interactivity today, without Web browser plug-ins, is by using a <iframe> element. The 
<iframe> element serves as the communication proxy for the Web browser. Data is 
transmitted to the server by utilizing a <form> element and either the "post" or "get" 

20 method. Alternatively, one could transmit data to a Web page without utilizing the 
<form> element by dynamically changing the "src" attribute of an <iframe> element at 
the Web browser. The <iframe> method for data transmission overcomes the limitations 
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of Microsoft's "Remote Scripting," but introduces one new serious limitation, which 
greatly compromises the operation of Microsoft's Web browser. 

Specifically, each time new information is loaded into an <iframe> element, a 
record or URL (Universal Resource Locator) is added to the Microsoft Web browser's 
5 history list. That is, the browser is now adding every action performed from the Web 
page to the history list, rather than just each unique Web page. Thus, since each unique 
Web page may make several data transmissions, several history records are now being 
associated with each unique Web page. This is problematic in the context of Web-based 
applications for the following reasons: 
10 1. Clutters the history list; users must navigate through a large directory tree full 

of redundant entries before finding the desired Web page. 

2. Compromises Web page navigation: users must repeatedly click on the 
"Back" or "Forward" buttons before being able to leave the current Web page. 

3. Produces undesirable application operations: users will trigger duplicate 
15 operations at the server (e.g. charge my credit card) when navigating with the 

browser's "Back" and "Forward" buttons. 
These problems affect many Internet users today as the majority of these users utilize a 
Microsoft Web browser. Furthermore, as Netscape winds down its Web browser 
business and Microsoft becomes the de facto Web browser, this problem will soon plague 
20 every single Internet user, and thus cannot be ignored. 

Consequently, NetGratus Inc. developed a method for transmitting data to and 
from a server by utilizing the <script> element as the communication vehicle. This 
method prevents unwanted history records from being added to the browser's history list, 
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however, introduced a new limitation. When data is transmitted via the <script> element, 
the Web page is limited in the amount of data it can transmit to a server. This is due to 
the fact that the <script> element utilizes the "get" method to transmit data. If the "post" 
method could also be utilized to transmit data, however, data could be transmitted to and 
5 from a displayed Web page without limitation of size. 

From the discussion above, it should be apparent that there is a need for better 
method of transmitting data between a displayed Web page and the server over HTTP. 
Specifically, a method that offers at least the same benefits of the <iframe> method, 
without disrupting the Microsoft Web browser's history list. The present invention 
10 fulfills this need. 



BRIEF SUMMARY OF THE INVENTION 

The invention permits a Web page to make JavaScript-based remote procedure 
calls (RPC) from Microsoft Web browsers to a server by using the HTML <form> and 

15 <iframe> elements, without adding a record (or Universal Resource Locator, URL) to the 
browser's history list. The Web page essentially uses HTML <form> and <iframe> 
elements as the communication vehicle for sending and receiving data to and from the 
Web server. As part of this invention, it enables submission of data to a server such that 
the response is no longer delivered onto a new HTML page, but rather to a hidden HTML 

20 <iframe> element. 

This invention enables web developers to create web-based applications that 
utilize a pure-Internet architecture (i.e. where the thin client utilizes only JavaScript and 
HTML) that yield a traditional fat client application experience, without all the weight 
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and limitations of the fat client. This is accomplished by, returning new information from 
server-side business logic to the displayed HTML page, and by using JavaScript/DHTML 
to alter the presentation layer accordingly. More specifically, this invention allows for 
data to be submitted to a particular procedure residing at a server, and return the response 
5 from that procedure to the displayed Web page over HTTP. 

This invention enables these interactions between the Web page and server by 
utilizing a client-side proxy, the client's communication agent, and a server-side proxy, 
the server's communication agent. The client-side proxy is ultra-fast and ultra-light since 
it is built using 100% JavaScript and HTML (<form> and <iframe> elements) 
10 technology. The server-side proxy can be implemented on virtually any platform, such as 
dynamic server pages (e.g. ASP, PHP, JSP, CFM, etc.), ISAPI-based C/C++, Java 
technologies, and so on. 

BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWING 
15 FIGURE 1 shows a system having a Web page on client computer and Web 

server constructed in accordance with the present invention. 

DETAILED DESCRIPTION OF THE INVENTION 

Typically, a Web page sends data from a web page to the server when an HTML 
20 form is submitted. This usually occurs when the user clicks the submit button of the 
HTML form. Once the submit button has been clicked, the browser collects the values 
from the form fields, builds an HTTP request, and then sends that request to the server. 
The server receives the information, does what it needs to do - querying a database for 
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example - and then returns the result of the form submission, usually in the form of a 
new HTML page. 

This invention uses the HTML <form> element in conjunction with a hidden 
HTML <iframe> element to yield completely different results than previously. Upon a 
5 trigger event, such as a mouse-over or a button click, the Web page now places a remote 
procedure call (RPC) through a client-side proxy, and will receive the results in a hidden 
<iframe> element, such that the displayed page is no longer refreshed. Additionally, 
using the <iframe> element to receive the results will no longer add a record of the RPC 
or URL to the browser's history list, 
tff 10 Once the RPC has been triggered, the client-side proxy includes the necessary 

J parameters for executing the RPC, including the location and name of the remote 
j| procedure, the data being passed to the remote procedure, the callback function name, 
^ etc. The client-side proxy must also prepare to receive the returned data. It dynamically 

SJ generates a hidden HTML <iframe> element at the Web browser, and sets the <form> 
O 15 element's "target" property to the <iframe> element. 

^ Now that the client-side proxy is prepared to send the request and receive the 

response, the <form> element is used to send the request to the Web server. Although 
the "post" or "get" request method can be used to submit the form; this invention utilizes 
the "post" method so that the data submitted to the server may exceed 1 kilobyte in size. 
20 Once the HTTP request arrives at the Web server it is passed to the server-side 

proxy. First, the server-side proxy parses the HTTP request to extract the necessary 
parameters. Then it regenerates the RPC as if it were a local procedure call. After the 
call has dispatched, the server-side proxy receives the returned data from the procedure, 
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packages that data in a format, which is understood by the client-side proxy, and returns 

that data package or response via HTTP to the <iframe> element. 

When the data is received by the <iframe> element, a callback function is invoked 

to process the returned data. The callback function is a JavaScript function of the Web 
5 page, which will process the returned data. It may display the data to the user, or use it 

carry out another task, such as performing another calculation (at the client or server). 

This entire process is accomplished without having to refresh the page. 

Now, in order to avoid adding a URL to the browser's history list, a given 

<iframe> element can only be used once per RPC. Therefore, for each new RPC, the 
10 client-side proxy generates a new <iframe> element at the Web browser, and deletes the 

previous instance of the <iframe> element, as if the previous <iframe> element had never 

existed. Although a new <iframe> must be used for each RPC, the same <form> element 

may be used over and over. This unique practice and method for disposing of the 

<iframe> element is a key aspect of this invention, which greatly increases the usability 
15 of a Microsoft Web browser. Specifically, it prevents the history list from becoming 

cluttered with frivolous records or URLs associated with each RPC, and more 

importantly, it maintains the usability of the browser's "back" and "forward" buttons for 

navigating between Web pages. 

20 System Configuration 

FIGURE 1 shows a system 100 having a Web page on client's computer 101 and 
one Web server 107. Web page 101 includes a client-side proxy 102, which contains 
HTML <form> 103 and <iframe> 104 elements. Client-side proxy 102 can communicate 



8 



with the Web server 107. The client-side proxy 102 assembles the HTTP request and 
sends it to the Web server via <form> element 103. The Web server utilizes server-side 
proxy 108, which handles HTTP the requests from client-side proxy 102 and dispatches 
the procedure calls to various server procedures 109. Server procedures 109 can access 
5 data sources, such as database 110, and return those results to server-side proxy 108. The 
server-side proxy 108 then packages the results into a format understandable by the 
client-side proxy 102, and returns that data package to the client-side proxy. The 
<iframe> element 104 at the client-side proxy 102 then accepts the data returned from the 
server-side proxy 108. Once this data is loaded into the <iframe> element 104, it is 
10 accessible to client- side processes and a callback function is triggered at the client- side 
proxy 102 to process returned data. 



System Implementation 

The next section shows a sample code for implementing the client-side proxy 102. 
15 The received data is stored in the <iframe> element until the new <iframe> element is 
generated by the next RPC. The <iframe> element is only used once to prevent adding a 
record of the RPC or URL to the Web browser's history. The code below is taken from 
the sample Web page "client.htm." 

<html> 

20 <script> 

var ifrCount=0 

function _I(callback, param) 

{ 

window.status=' ,n ; 

25 eval(callback + "("' + param + '")"); 

} 

function LMLPost(serverPage, callback, serverFunction, data) 
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20 



var strHTML=new String(); 
if ( !document.forms.LMLform) 

{ 

strHTML="<div><form name=V , LMLform\ ,, 
5 method=\ n postY'action=\ m, + serverPage + T> M ; 

strHTML+="<input type=Y'hiddenY l name=\ ,, func\ ,, > ,, ; 
strHTML+= M <input type=V , hidden\ n name=\ ,, params\ ,, >"; 
strHTML+= n <input type=\ M hidden\ n name=\ M callback\"> n ; 
strHTML+= n </form></div> n ; 
10 document.body.insertAdjacentHTML( M BeforeEnd n ,strHTML) 

} 

if(ifrCount>0) 

document.allCdiv_'+(ifrCount-l)).innerHTML="; 
1 5 document.forms.LMLfonn.func. value = serverFunction; 

document.forms.LMLform.params.value = data; 
document.forms.LMLform.callback. value = callback; 
strHTML= M <div id='div_ ,, +ifrCount+ ,M ><iframe 

style=\ ,, position:absolute;visibility:hidden;left:0;top:0\ n 
name = *' + ifrCount +" V</iframe></div>"; 
document.bodyinseitAdjacentHTML( l, BeforeEnd , ',strHTML); 
documentiorms.LMLform.target="+iftCount; 
documentiorms.LMLform.submit(); 
ifrCount++; 

25 } 

function post_data() 
{ 

LMLPostC'he^asp", "my.callback", "getData", 
30 document.all('input_buffer').value); 



function my_callback(data) 
{ 

35 document.allCoutput.buffer 7 ). value = data; 

} 

</script> 
<body> 

<textarea name^'inputjniffer' rows=8></textarea> 
40 <textarea name^outpuLbuffer' rows=8></textarea> 

<input type= button' value^ost' onclick="post_data();"> 

</body> 

</html> 



45 As shown in the above sample codes for both Web page 101 and the client-side 

proxy 102, the client-side proxy 102 uses a <form> element 103 as the postman to send 
data to the Web server and uses <iframe> element 104 as the receiver to receive the 
returned data from the server proxy 108. This invention uses the <form> and <iframe> 
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elements together in a combined new and innovated way to transmit data between the 
displayed Web page and a server, and more specifically to make an RPC, without adding 
a URL to the Web browser's history list. 

Each time a Web page makes a RPC, the client-side proxy 102 generates an 
5 HTTP request that includes the location and name of the remote procedure, any data to be 
passed to the remote procedure, and the callback function name. This HTTP request is 
posted to Web server 107 through the submission of <form> element 103. The response 
arrives to <iframe> element 104 and triggers the specified callback function, so that Web 
page 101 can process the returned data. 
10 The server-side proxy 108 can be implemented by any Web server-side 

technologies, such as, ASP, PHP, JSP, EJB, ISAPI, and so on. The next section shows an 
implementation of server-side JavaScript code running on Microsoft's IIS Web server. It 
can be easily ported to other Web server-side technologies. The following code is taken 
from the server proxy file "serverproxy.inc." 

15 <%@ Language=JavaScript %> 

<% 

var JLML_PARAMS_DELIM = String.fromCharCode(l); 

var i, strBody, strResult; 

var strFunc, strCallback; 
20 var strParams, arrParams; 

strFunc = Request("func").item; 

strParams = Request("params").item; 

strCallback = Request("callback").item; 

arrParams = strParams. split(_LML_PARAMS_DELIM); 
25 strParams = H "; 

for (i = 0; i < arrParams .length; i ++) 

{ 

if (i > 0) 

strParams += 

30 strParams += T n + EscapeSpecialChars(arrParams[i]) + T"; 

} 

strResult = escape(eval(strFunc + "(" + strParams + ")")); 
strBody = !, <HTMLxHEAD></HEAD>" 
strBody += "<BODY onload=parent.window._I("; 
35 strBody += T" + strCallback + TV; 



11 



strBody += T" + strResult + T"; 
strBody +=")>'■; 

strBody += "</BODY></HTML>"; 
Response.Write(strBody); 
5 function EscapeSpecialChars(strSrc) 

{ 

var strDest = strSrc; 
strDest = strDest. replace(AVg, \\\Y)\ 
strDest = strDestreplace(Ar/g, Wr 7 ); 
10 strDest = strDestreplace(An/g, 'Wn'); 

strDest = strDest.replace(/7g, \\Y ,T ); 
strDest = strDest.replace(/7g, \\\"); 
return strDest; 

} 

15 %> 



The next section shows the sample code for server function 109. This is an 
implementation for Microsoft IIS and ASP. It can be easily ported to other Web server- 
side technologies. The first line is used to include the source code of server proxy 108. 
T 20 The simple "getData" function herein returns whatever data it takes as the input 
argument. The code below is taken from the sample server page "serv^asp." 

<!--#include file="serverproxy.inc"--> 
<script runat=Server language=VBScript> 
function getData(strPara) 
3 25 getData = strPara 

end function 
</script> 



The above sample codes illustrate a sequential RPC process. By using additional 
30 <form> and <iframe> elements, however, the client-side proxy 102 can make multiple 
simultaneous RPCs. Although the source code above enables a Web page to directly 
access server-side procedures through the "post" request method, with little modification, 
it can also enable a Web page to directly access services provided by server-side objects 
through the "get" request method. 
35 The present invention has been described above in terms of presently preferred 

embodiments so that an understanding of the present invention can be conveyed. There 
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